package com.hanserwei.community.entity.po;

import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.annotation.TableField;
import com.baomidou.mybatisplus.annotation.TableId;
import com.baomidou.mybatisplus.annotation.TableName;
import io.swagger.v3.oas.annotations.media.Schema;

import java.io.Serial;
import java.io.Serializable;
import java.math.BigDecimal;
import java.time.LocalDateTime;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;

/**
 * 房屋信息表
 */
@Schema(description="房屋信息表")
@Data
@AllArgsConstructor
@NoArgsConstructor
@TableName(value = "house")
public class House implements Serializable {
    @Serial
    private static final long serialVersionUID = 1L;

    /**
     * 房屋ID，主键
     */
    @TableId(value = "id", type = IdType.AUTO)
    @Schema(description="房屋ID，主键")
    private Integer id;

    /**
     * 所在楼层
     */
    @TableField(value = "storey")
    @Schema(description="所在楼层")
    private Integer storey;

    /**
     * 房间的号码，如：101、102
     */
    @TableField(value = "numbers")
    @Schema(description="房间号码，如：101、102")
    private String numbers;

    /**
     * 房屋状态：0-空置，1-已入住
     */
    @TableField(value = "`status`")
    @Schema(description="房屋状态：0-空置，1-已入住")
    private Integer status;

    /**
     * 入住时间
     */
    @TableField(value = "into_date")
    @Schema(description="入住时间")
    private LocalDateTime intoDate;

    /**
     * 所属建筑物ID，关联building表
     */
    @TableField(value = "building_id")
    @Schema(description="所属建筑物ID，关联building表")
    private Integer buildingId;

    /**
     * 房屋描述
     */
    @TableField(value = "remarks")
    @Schema(description="房屋描述")
    private String remarks;

    /**
     * 房屋面积（平方米）
     */
    @TableField(value = "area")
    @Schema(description="房屋面积（平方米）")
    private BigDecimal area;
}